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ABSTRACT 


The purpose of this study was to develop the digital sampling and control system 
for an Unmanned Air Vehicle (UAV) designed to takeoff and land vertically and 
to transition to forward flight. The system is designed to operate from a personal 
computer through an umbilical cable tethered to the platform for hover tests. The 
computer controls the sampling and digital conversion of onboard analog sensor 
signals and sends control-surface commands for pitch, roll and yaw motions. 

The thesis effort includes the following four parts: 
ө Design of a controllable Pulse-Width-Modulated Signal (PWMS) to command 
the servos which operate various aerodynamic surfaces. This control is 
accomplished with software written to a counter/timer card installed in the 


computer. 


e Sampling and conversion of the signals to the sensors through the 
programming of an analog-to-digital card installed in the computer. 


€ Sensor power-up and parameter verification of onboard devices. 
€ Development of various power networks to allow operation of onboard 
systems prior to engine start with the ability to be self-sustaining once the 
engine is running. 
The system was fully tested during ground runs on a thrust/torque test stand. 


Integration of the system with the robust controller designed in a concurrent thesis 


will provide for the stability necessary for the innovative unmanned vehicle. 
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I. INTRODUCTION 

During Operation Desert Storm it did not take long for commanders of ground 
and Naval forces to realize the utility of intelligence gathering through the use of 
Remotely Piloted Vehicles (RPV). The current RPV Pioneer allowed for real-time 
data gathering without risk to human life. The use of RPV's allowed Marines and 
Naval forces alike to become self-supporting integrated platforms. 

Even with the success of Pioneer in the Gulf War, there still lies room for 
improvement in the current system. It was noted that once the ground offensive 
began, Pioneer had trouble keeping pace with the rapid ground movement. A 
major problem with the system was the large amount of equipment and groomed 
runway needed for the land-based Pioneer. Due to these shortfalls, Pioneer 
provided little benefit during a time when it could have been irreplaceable as a 
real-time intelligence gatherer, or spotter for Naval and Marine gunfire. 

An Unmanned Air Vehicle (UAV) based on a Vertical-Takeoff-and-Landing 
(VTOL) configuration could sii help to solve many of the current UAV 
shortcomings. One candidate for such a platform is a ducted-fan airframe with 
wings attached. The advantage of the ducted-fan configuration is that it provides 
safety from propeller blades for close operation to ground troops. Positioning the 


duct and wings vertically would allow the vehicle to take off vertically, hover to 


altitude and then pitch over to achieve horizontal flight. This concept has the 
advantage of needing limited space for takeoff and landing. Additionally, the 
ability to transition to horizontal flight will extend the vehicle’s range, and allow 
faster dash speeds than for a vehicle that translates like a helicopter. The reduced 
fuel consumption of a fixed-wing over a hovering vehicle will allow for longer 
loitering periods once the air vehicle is on station. Such a platform is being 


developed at the Naval Postgraduate School (NPS), named Archytas. 


NPS will determine: 


e The proper propulsion and aerodynamic design to vertically lift the vehicle; 


€ The necessary stability augmentation system to control the vehicle in vertical 
flight; 


€ The optimum maneuver for transitioning the vehicle from a vertical hover to 
horizontal flight; and 


€ The necessary ground control needed to provide commanded input to the 

vehicle while hovering and in horizontal flight. 

The goal of this work was to develop the digital sampled data control system 
for a VTOL UAV. The integrated system will interface a ground computer with 
onboard systems to allow for inputs from the onboard sensors to be sampled 
through the umbilical and converted to a digital signal by the computer. These 


digitized signals can then be applied to control the vehicle's pitch, yaw and roll 


rates [Ref 1]. The control equations will generate commands that will be sent to 
the control vanes on the vehicle to adjust the vehicle's attitude. 
This investigation examined: 
e The development of a computer-generated Pulse-Width-Modulated Signal 
(PWMS) to command five servos through an umbilical. The signal 
commands the throttle and the position of four control surfaces on the 


vehicle. 


@ The development of a system to sample the signals from onboard sensors and 
convert them to 12-bit digitized form. 


€ A power system to allow all the electronics to operate prior to, and after the 
engines generator is up and running. 


e The design of the vehicle hardware components to include the umbilical and 
associated connections, housing and power system and all associated wiring. 

The results support the effort to digitally control a VTOL UAV in a hover. 
Follow-on projects will perform the integration of vehicle control for forward 


flight, and miniaturization of the computer for autonomous flight. 


II. BACKGROUND 


A. NAVY UAV APPLICATIONS AND REQUIREMENTS 

The Navy's Unmanned Air Vehicle (UAV) program currently lacks an 
adequate vehicle that will take off in a small area and yet have a long loiter time 
to conduct operations once on station. The Navy has defined a need for a vehicle 
that will take off vertically and conduct extended reconnaissance. The concept 
designated as VIPER (Vertical Takeoff and Landing Integrated Platform for 
Extended Reconnaissance) whose specifications are described in Reference 2 call 
for a vehicle able to land and takeoff in an area smaller than a LAMPS flight 
deck. The requirements of VIPER also state that it should be able to transit 
100nm from the ship in a 25-knot headwind in less than one hour and be able to 
loiter on station for three hours. The primary missions of the vehicle would be 
for Reconnaissance, Surveillance and Target Acquisition (RSTA) and Over-The- 
Horizon-Classification-and-Targeting (OTH-C&T). The ideal vehicle should be 
highly portable, have a small operations contingency, and be able to operate ashore 
as well as at sea. 

At the Naval Postgraduate School UAV Flight Research Lab, the Navy has 


been developing a ducted-fan VTOL vehicle. This vehicle could be a proof of 


concept vehicle to meet the requirements of VIPER or accomplish similar 
missions. The vehicle will encompass all the personnel safety qualities of a 


shrouded propeller with the dash and loiter advantages of a fixed-wing vehicle. 


B. THE ARCHYTAS CONCEPT 

The NPS air vehicle Archytas, named for the Greek contemporary of Plato 
credited with designing and flying a mechanical bird, 1s serving as a platform to 
test the concepts of a winged ducted-fan VTOL aircraft. The vehicle utilizes the 
technology and equipment developed in two cancelled military programs to 
produce a quality experimental test platform. The U.S. Marine Corps program 
produced the Airborne Remotely Operated Device (AROD), and the U.S. Army 
program developed the AQUILA (Latin for eagle). Both programs, though 
successful in their original missions, were cancelled, providing assets for 


development of new programs. 


1. AROD Program 
The major parts of the Archytas have come from the AROD program, 
the vehicle which was designed by Sandia Laboratories in conjunction with the 
Naval Ocean Systems Center [Ref 3]. The AROD was onginally designed to be 
a short-ranged hovering vehicle. The vehicle was designed to be controlled by 


fiber optic link or remotely with a modified commercial modeler’s radio. The 


vehicle, which resembles a 3-ft-diameter duct, was powered with a vertically- 
mounted 28-horsepower engine turning a three-bladed propeller. Four vanes were 
positioned on the vehicle in the propwash to provide the ability to correct or 
change the attitude of the vehicle. 

The use of a single propeller in a duct simplifies the design, but creates 
stability problems caused by the torque of the engine and by gyroscopic coupling 
of the pitch and yaw moments. This problem was overcome by Sandia with the 
development of a Multiple Input Multiple Output (MIMO) robust controller that 
utilized sensors coupled with a Motorola 68000 Central Processing Unit (CPU) to 
apply the devised control laws. The output from the CPU was converted into the 
necessary signal to position the vanes for the desired effects. 

The AROD, weighing about 85 pounds and producing about 105 pounds 
of thrust, first flew successfully in 1986. Its endurance was limited to one hour 
due to the high power level needed for hovering. The vertical design and axial 


flow of the propwash limited the vehicle’s forward speed. 
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2. Aquila Program 
The AQUILA, the vehicle that provides the wings for the Archytas, was 
an ARMY-developed UAV designed by Lockheed [Ref 3] as a mid-range fixed- 
wing tailless pusher platform. The airframe is a composite structure with a 13- 


foot wing span and length of 7 feet. The vehicle was powered by a horizontally- 


mounted 24-horsepower engine. The vehicle wing elevons (acting as elevators and 
ailerons) were the primary surfaces to control the vehicle in flight. The AQUILA 
needed a sophisticated dedicated flight control electronics package to provide 
control and stability. 

The design of the Archytas has taken the AQUILA wings and attached 
them to the duct used in the AROD program. It was also necessary to add a canard 
to provide an improved means of longitudinal control. The duct and wings will 
be vertically oriented as a tail-sitting airplane. The vehicle will be designed to 
hover to a determined altitude while the controller commands the four control 
vanes that will maintain pitch, yaw, and roll rates. Once at altitude the vehicle 
will then roll over to horizontal flight which will allow for an increased forward 


speed and an improved endurance. A sketch of the vehicle is shown in Figure 1. 
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Figure 1: Sketch of Archytas 


III. THE DIGITAL CONTROL INTERFACE SYSTEM 


A. SYSTEM OVERVIEW 

The instability of the Archytas vehicle requires a computer controller to 
control pitch, roll and yaw motion. A digital controller requires input from 
onboard sensors, and the ability to command a surface to generate the desired 
response. The original AROD computer, a Motorola 68000 CPU provided the 
controller and interface functions. This system was not used because it was 
outdated and it would have been difficult to find interfacing equipment for it. 
With this in mind, it then became necessary to develop a new interface system. 

The flexibility and low cost of personal computers made it desirable to 
develop the system centered around an IBM personal computer. The initial testing 
of Archytas will involve the vehicle in a hover. This means the vehicle can be 
ground linked to a personal computer through an umbilical. The umbilical will 
allow the computer to sample and evaluate the sensor data. After the sensors’ data 
is evaluated, the computer can then send a command for vane angle through the 


umbilical to one or more of the four control vanes. The umbilical link can also 


be used to control the throttle servo from the ground. Once this system is proven, 
the computer system can then be miniaturized to allow onboard placement. 

Enabling the computer to complete its tasks required the addition of two 
special-function cards to the computer. The first card added (Diamond Systems 
Quartz I/O) generates the Pulse-Width-Modulated Signal (PWMS) to control the 
four control vanes and throttle. The Quartz card is a multi-purpose card with the 
AM9513A system timing controller as the main chip aboard the card. The chip 
has a versatile group of modes ranging A-X that are shown in the users manual. 
The card has five expandable to ten extremely versatile 16-bit counter groups. 
Each group of counters has a wide variety of features, including up/down counting 
by binary, or binary coded decimal, edge level gating, and a toggle output 
capability. The card has an internal series of frequencies derived from a 1 MHZ 
oscillator that can be exported. Additionally, the counter/timers can be used to 
generate retriggerable one-shots of varying duty length. A list of the card’s 
specifications and a pin diagram for the output port can be found in the users 
manual. 

The second card installed is the CIO-ADl6jr card by Computerboards that 
provides sampling and analog-to-digital conversion. The card ıs a 16-channel 
open-ended input, or 8 differential input, card. Aboard the card ıs an 8254 chip 


that provides a versatile range of methods for trıggering the conversion process. 
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The card converts from analog to digital by successive approximation with a 
conversion time of about 3 nanoseconds. A useful feature the card provides is the 
ability to vary the input through various ranges from a bipolar +/- 10V to a 
unipolar 0-1.25V. 

The final systems to be engineered were the utility systems. These systems 
included the umbilical and power systems. The power system included voltage 
supply for the sensors, electronic ignition and a signal conditioning card. This 
system was difficult to design because of the diversity of each system. A major 
difficulty in the design of the power system was the need for it to fit compactly on 
the vehicle. Additionally, the various systems all needed to interface with each 
other as well as with the computer. A concern for the power system was the need 
to provide power to the various systems prior to the engine generator being up and 
running. A basic overview of the overall system is shown in Figure 2. Each of 
the basic systems SERVO CONTROL, ANALOG TO DIGITAL, and UTILITY 


SYSTEMS will be described in the following chapters. 


, 
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Figure 2: Basic Electrical System Design 


IV. GENERATION OF THE SERVO CONTROL SIGNAL 


A. GENERAL LAYOUT OF THE SERVO CONTROL AND QUARTZ I/O 

CARD 

The digital controller needs the ability to command movement of the control 
surfaces on the vehicle. The original AROD design used Futaba S-134 servos to 
move each of the four control surfaces. These servos are general-purpose hobby 
remote-control items that cost about $40.00 each. The servos have three inputs: 
(1) 5 volts; (2) ground; and (3) a Pulse-Width-Modulated-Signal (PWMS). The 
5-volt signal powers a small DC motor, and the small amount of Transistor 
Transistor Logic (TTL) onboard the device. A PWMS is characterized by a 
square wave whose duty cycle varies between 0.6 and 2.4 milliseconds. The 
width of the pulse drives the servo proportionally to the intended position. A 
narrow pulse of 0.6 milliseconds may drive the servo hard right, while a 1.0 
millisecond pulse will drive the servo proportionally less right, and a 2.4 
millisecond pulse may drive the servo hard left. The servo PWMS is refreshed 
every 10 milliseconds. The addition of the Diamond System Quartz I/O card to 
the PC provided the ability to create the PWMS to command the servos. Figure 


3 shows atypical PWMS. The user's manual for the Quartz I/O card was 
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Figure 3: Pulse Width Modulated Signal (PWMS) 
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written with the intention of the card being used in conjunction with proprietor 
software written in Basic or C. This documentation was not adequate, or useful 
in the generation of the desired PWMS. This is mainly because the modes (A-X) 
set up count on a "CALL" to a routine that is only provided in object code. This 
"CALL" to a subroutine is not explained in the card’s documentation, making it 
difficult to understand exactly what is being done. Additionally, the C programs 
are only compatible with Microsoft C, not with Borland C. Since the "CALL" 
routine was not provided, it was necessary to register-level program the desired 
mode into the AM9513A, the onboard system timing controller chip. The data 
sheet for the AM9513A chip is included in the manual. The data sheet allowed 
the card to be programmed at register level to obtain the desired output. All of 
the programming was done in Borland C to provide a robust environment for later 
use. 

To allow the PC to interface with the card, the first step is to set the BASE 
ADDRESS dip switches to a non-interfering address that the C programs will 
interface with. For this application the BASE ADDRESS 225 hex was set on the 
onboard dip switches. The location of the dip switches on the card is shown in 
users manual. This selects the base address of the port the program will write to, 
or read from. The card is read and written to at one of three addresses which are 


each eight bits, or one byte wide. Table 1 describes each of the functions 


associated with the base addresses and their offsets. The general layout of the 
AM9513A registers’ access 15 shown in Figure 4. 

The data bus multiplexor selects either the CONTROL PORT (BASE 
ADDRESS +1), or the DATA PORT (BASE ADDRESS), depending on which 
address the binary word is being written to. The CONTROL PORT determines 
which register incoming data will be loaded into to select the operating mode of 
the card. The card can be programmed in any mode chosen from those offered 
in the data sheet between modes A through X. The data sheet showed that 
programming mode F allowed generation of the desired PWMS. 

TABLE 1: QUARTZ CARD INPUT/OUTPUT MAP 


OFFSET FROM 


BASE ADDRESS WRITE READ 

0 9513 #1 DATA REGISTER 9513 #1 DATA REGISTER 

1 9513 #1 CONTROL REGISTER 9513 #1 STATUS REGISTER 

2 INTERRUPT ENABLE DIGITAL INPUT PORT AND 
INTERRUPT RESET 

3 DIGITAL OUTPUT PORT NO FUNCTION 

4* 9513 #2 DATA REGISTER 9513 #2 DATA REGISTER 


55 9513 #2 CONTROL REGISTER 9513 #2 STATUS REGISTER 


* CHANNELS ARE ONLY USABLE IF CARD IS SET UP FOR 10 
CHANNEL OPERATION BY ADDING THE SECOND AM9513A TO 
THE CARD. NPS CARD IS NOT SET UP FOR 10-CHANNEL 

OPERATION. 
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Figure 4: AM9513A Register Access 
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B. PROGRAMMING MODE F ON THE QUARTZ I/O CARD 
1. Programming Overview 

To enable the card to produce the desired PWMS, each of the five 
AM9513A counters is programmed for mode F. The programming is all done in 
Borland C. Borland C has a function called "outportb(address,command)" that 
outputs the 8-bit decimal number to the output port desired. To begin programming 
the card, the card must first be reset. Then the Master Mode Register (MMR) must 
be programmed to control the overall function of the card. Then each of the five 
counters must be programmed through each counter's Counter Mode Register 
(CMR). Each of the five counters has two additional multi-purpose registers that can 
be programmed, called LOAD and HOLD registers. 

The LOAD and HOLD registers play key roles in the generation of the 
desired signal. The individual channel counter alternates 1n being loaded from its 
respective LOAD and HOLD registers. The HOLD register contains a number that 
when loaded in the counter counts down to zero and fires a one-shot high (5V) 
creating the 10 ms refresh rate of the signal. Once the hold register counts down, 
the counter 1s then toggled to be loaded with the number contained in the individual 
counters LOAD register. The signal is held high until the LOAD register count 
reaches zero, causing the one-shot to be reset (0V). The count in the LOAD 


REGISTER creates the desired pulse-width between 0.6-2.4ms. Varyıng the number 
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loaded in the LOAD register varies the pulse-width. When the LOAD register counts 
to zero the counter toggles and 1s loaded from the HOLD REGISTER beginning the 
count down till the signal will be refreshed again. 
2. Detailed Programming of the Registers 
Most register programming commands for the Quartz I/O card are two- 
part commands. The first command is loaded through the CONTROL PORT. It 1s 
an 8-bit command that generally points to the register to be loaded. The second 
command, a 16-bit command, is loaded in two 8-bit bytes through the DATA PORT, 
8 bits at a time. Figure 5 shows the DATA POINTER register, which shows how 
to access every available register that will need to be loaded. Sending the 
appropriate decimal equivalent to the CONTROL PORT sets up the multiplexor to 
load the next DATA PORT entry into the appropriate register. 
a. Programming the Master Mode Register (MMR) 
The first step to program any mode in the card is to reset the card. 
Reset is accomplished by writing 255 (binary 11111111) to the CONTROL PORT 
(base address--1). This reset command is found in Figure 6. 
The next step is to program the MMR. This is accomplished by 
writing 23 (binary 00010111), obtained from the DATA POINTER (Figure 5) 
register to the CONTROL PORT to select the MMR. Figure 7 shows all the 


possible selections of the MMR. Then the 16 bits of data are loaded into the MMR 
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8 bits at a time through the DATA PORT. The first 8-bit number 176 (binary 
10110000) is loaded followed by the second 8-bit 65 (binary 01000001). This bit 
assignment selects the MMR (Figure 7) to operate in the manner described in Table 
2. Most of the selections in the MMR are arbitrary and have little effect on the 


PWMS, but do need to be specified for operation of the card. 
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Figure 5: Data Pointer Register 


TABLE 2: BIT ASSIGNMENT FOR MASTER MODE REGISTER 


BIT ASSIGNMENT BITS FUNCTION 


MM15,MM14,MM13,MM12 1011 


MMII,MMIO,MM9,MMS$ 0000 
ММ7,ММ6,ММ5,ММ4 0100 
ММ3,ММ2,ММ1,ММ0 0001 


BCD DIV,DISABLE 

INCR, 8BITBUS, FOUT ON 
FOUT IS DIVIDED BY 16 
FOUT SOURCE IS F1 1 MHZ 
(FIGURE 8) 

DISABLE COMPARE 1 AND2 
DISABLE TIME OF DAY 
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Figure 6: AM9513A Command Summary Sheet 






C000 = Os by 16 0000 o E1 

0001 = Olvide By 1 0001 = GAC 1 
0010 • Оми by 2 0010 e ФАС 2? 
0011 = Омо Ву 3 0011 = ЗАС 3 
0100 = Dhade by 4 0100 = ФАС 4 
0101 = Оми by 6 0101 = ВАС 6 
6110 = Оми Ву 6 0110 e QATE 1 
1000 = Оми by 6 1000 е GATE 3 
тета Бреал ar > 
1011 = Dhade by 11 Мртав 
1100 — Otto by 12 1100 e Р? 

1101 • Омбе 9. 1:01 = РЭ 





Compare ? Bnsbie —) | 
0 * Osatted | 
eo 1 © Enebied | 
uin (Due Ui. Sugar 1 eet 
0 = 60M hs 0 = Овабов 
1 109-08 Bus 1 = Enabied 
owe Palta: Costra! vmo-c Do; edo 
O e Enable ғсғетегі 00 = ТОО Disabled 
1 = Dugbis increment 01 e YOO Enabled: 
10 е ТОО 
- ТОО | 


ur Se 
© = Binary Division " 
1 e SCD Division 
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b. Programming of the Counter Mode Register (CMR) 

The Quartz I/O card and in particular the AM9513A Integrated 
Circuit (1.C.) has five programmable counters. The Archytas vehicle needs all five 
counters to output the needed PWMS. Counters one through four output the PWMS 
that control the servos that change the vane positions. Channel five outputs the 
PWMS that controls the servo for throttle movement on the engine. Therefore, all 
five CMR need to be programmed the same, and are done successively. Loading a 
l-5 to the DATA POINTER register (Figure 5) through the CONTROL PORT 
selects any of the five CMR. The following example illustrates the process for 
loading counter one; the other four are done in the same manner. 

The first step in programming CMR one 1s to load a one (binary 
00000001) in the CONTROL PORT to select counter one CMR. The next step is 
to load the low and high bytes into the CMR via the DATA PORT. The low byte 
loaded is 98 (binary 01100010), and 27 (binary 00011011) is the high byte loaded. 
The bit assignment list shown in Figure 8 and Table 3 show the CMR bit assignment 


causing various important actions to occur. 
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Figure 8: Counter Mode Register Bit Assignment 


TABLE 3: COUNTER MODE REGISTER BIT ASSIGNMENT 


BIT ASSIGNMENT BITS 
CM15,CM14,CM13,CM12 0001 


CM11,CM10,CM9,CM8 1011 


CM7,CM6,CM5,CM4 0110 


CM3,CM2,CMI,CMO 0010 


FUNCTION 

NO EXTERNAL GATING, 

COUNT ON FALLING EDGE OF 
CLOCK 

COUNTER FREQUENCY SOURCE 
IS Fl THE OSCILLATOR SEE 
FIGURE 8 

DIABLE SPECIAL GATE, 
RELOAD FROM LOAD OR HOLD, 
COUNT REPETITIVELY, COUNT 
BINAR Y 

COUNT DOWN, WHEN TERMINAL 
COUNT IS REACHED ON LOAD 
REGISTER TOGGLE COUNT TO 
THE HOLD REGISTER. 
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Most of the above settings are self explanatory. The most critical 
setting 1s that of the count being toggled between the LOAD and the HOLD register. 
This is the heart of the PWMS. As discussed previously, the HOLD register is 
loaded with a number that when counted out, refreshes the signal to the servo by 
finng a one-shot to à high voltage level (5V). Once high, the LOAD register then 
counts out and resets the one-shot to a low value. The number in the LOAD register 
translates to the variable pulse width desired. 

c. Programming of the LOAD and HOLD Registers 

There are LOAD and HOLD registers for each of the five 
counters, which need to be loaded successively. The selection of any of the five 
counter LOAD registers can be accomplished by writing a 9-13 (binary 00001001 
through 00001101) as shown on the DATA POINTER register (Figure 5) through the 
CONTROL PORT. As before, the register is loaded with a high and low byte 
through the DATA PORT. The initial value loaded is a zero deflection angle of the 
PWMS translated to the servo that controls the vehicle vanes. To change the position 
of one of the five servos a new number is loaded into the LOAD REGISTER. This 
new number will be translated into a different width signal, "m is then sent to the 
servo to change its position at a refresh rate of 10 ms. 

The HOLD registers are also loaded successively. The selection 


of any of the HOLD registers is accomplished by loading a 17-21 (binary 00010001 
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through 00010101) into the DATA POINTER register through the CONTROL PORT 
as shown in Figure 5. Once this is accomplished, the low and high bytes are loaded 
as data into the DATA PORT. For the purpose of generating the PWMS, the HOLD 
register is loaded with a value that makes the refresh rate for all five channels 
approximately 10 ms. 
3. Final Programming Notes for Mode EF 

The final event that must occur to initialize the Quartz I/O card is to 
load and arm all counters. In reference to Figure 6, it can be seen that when a 
decimal 127 number (binary 01111111) is loaded into the CONTROL PORT all 
counters will begin to operate. These programming steps will allow the counter to 
operate until a disarm command is given. 

In Appendix A, a program used to generate the PWMS is given. The 
program allows for user interface to determine which counter and how much of a 
change of angle 1s desired. One equation 1s used in the program to convert a degree 
angle input to a number to load into the load register to obtain the desired pulse- 


1 


width. 
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V. PROGRAMMING THE COMPUTERBOARD'S ANALOG-TO-DIGITAL 
CARD 


A. COMPUTERBOARDS ANALOG-TO DIGITAL CARD OVERVIEW 

With the programming of the Quartz card we have the ability to control the 
vehicle. The next step in the development of the digital controller is a method to 
convert the onboard sensor information to digital form. This is accomplished through 
the use of the Computerboard CIO-AD16Jr 16-channel analog-to-digital card. The 
card is versatile 12-bit converter with variable crystal settings, eight differential or 
sixteen single-ended channels, and a programmable input voltage range. 

Similar to that for the Quartz card, the user’s manual for this card is 
designed to be used with proprietor software. For the purpose needed, seven of the 
manual’s 84 pages contain useful, but incomplete information. This is partly due 
to the fact that the proprietor software is provided in Basic. Additionally, a 
subroutine is used in every mode that requires a function "CALL" that is not 
provided in other than object code. To use the card for the purpose needed it was 
necessary to obtain the onboard counter/timer data sheet (Intel 8254), and to 
experiment with many of the settings. 

Prior to the card being installed in the computer, the board must be strapped 


for a non-interfering address. For this application the address was strapped for 300 
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hex. The additional address options can be found by referring to users manual. In 
addition to the address setting, the card was strapped for 1 MHZ operation and 16- 
channel single-ended input. The Direct Memory Address switch selection is not 
relevant since a IBM 386 machine handles memory transfers. 

The card is programmed in Borland C using the library functions 
"inportb(address)" and "outportb(address,data)" which allow access to external port 
addresses. The card allows for register level programming through sixteen 8-bit 
addresses that provide various functions. The analog-to-digital conversion method 
used is successive approximation with each conversion taking approximately 3 
nanoseconds. The input signal 15 converted to a 12-bit digital number. A summary 


of the function of each address 1s shown below in Figure 9. 
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ADDRESS 
BASE 
ВАЗЕ + 1 
ВАЗЕ + 2 
ВАЗЕ + 3 
BASE + 4 
ВАЗЕ + 5 
ВАЗЕ + 6 
ВАЗЕ + 7 
ВАЗЕ + 8 
ВАЗЕ + 9 
ВАЗЕ + 10 
ВАЗЕ + 11 
ВАЗЕ + 12 
BASE + 13 
BASE + 14 
BASE + 15 


WRITE FUNCTION 
Sia A/D Conversion 
ChamdMUXSa — Chanel MUX Read x 
Digital 4 Bit Output 

CTR 1 Data - A/D Pacer Clock CTR 1 Data - A/D Pacer 

CTR 2 Data - A/D Pacer Clock CTR 2 Data - A/D Pacer 

None. No read back on 8254. Pacer Clock Control (8254) 


Figure 9: A/D Card Address Overview 
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B. PROGRAMMING THE A/D CARD 

Programming the card requires the initialization of several of the addresses 
from Figure 9 for various desired modes. The first initialization is that of the 
Multiplexor (MUX). The MUX can have various functions. The MUX can set up 
the number of channels to be incremented through, or be used to point at a specific 
channel desired (1.e., 0-15). The MUX also is the device that points to the current 
channel, and increments to the next channel to be converted. The conversion process 
can be started 1n one of three ways, by software trigger, external trigger, or internal 
pacer clock trigger. The MUX also can be used to reset to the desired channel to be 
read. This is done by writing to the MUX where the upper 4 bits of the MUX 
contain the channel desired for conversion. The layout of the MUX register is shown 
in Figure 10. 

The MUX register 1s divided into two halves. The lower half (bits 0-3) of 
the register selects the starting channel to be converted. The upper half (bits 4-7) of 
the register selects the ending channel. The MUX points at the channel currently 
converted. Then, when triggered, the MUX increments itself and the STATUS 
register to the next channel to be converted in a continuous loop. Every write to this 
register sets the STATUS register channel and current A/D channel MUX to the 


number in bits 4-7. 
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BASE ADDRESS + 2 


CH H8 | ЕРЕСЕН CH HI CH Lg CH L4 | CH ЕСН as 











* CH refers to channel ** H refers to high channel 
** [, refers to low channel 


Figure 10: Set up of the Multiplexor register 

The next address to be initialized is the analog input range. All sixteen A/D 
channels can only input the selected voltage range. The voltage range can be one 
of the many values shown in Table 4. The layout of the register is shown in Figure 
ll. The selection of the appropriate bits from Table 4 written to base address + 11 
selects the desired input voltage range. A voltage range of 0-5V is the input range 
for the current configuration. This range is setup by writing a decimal five (binary 
00000101) to base address + 11. 


BASE ADDRESS + 11 


| RANG. | UNI/B 





Figure 11: Analog Input Range Register 
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TABLE 4: BIT SELECTION FOR ANALOG INPUT RANGE 


| UNI/BI 





rp EI 
AS 
Tia a 
=P= И ЫШЫ 


KKK SELECTED RANGE FOR THE APPLICATION 
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The next address initialized is BASE ADDRESS -9 which controls the 
Direct Memory Access (DMA), interrupt, and trigger control. DMA allows the 
program to store the most recently converted channels in a specific PC memory 
location. Although DMA is not used during this application, DMA should be 
considered for later development to increase operating speeds. BASE ADDRESS+9 
allows the selection of interrupts two through seven and allows them to be mapped 
onto the PC bus. Additionally, by the selection of the appropriate bits, the 
conversion trigger can be selected (bits 0 and 1). The DMA, interrupt and trigger 


control register 1s shown in Figure 12. 


BASE ADDRESS + 9 





Figure 12: DMA, Interupt and Trigger Control 


Selecting INTE=1 (bit 7) enables interrupts to be placed on the PC bus, 


while INTE set to zero disables interrupts. Bits 4-6 select the binary number of the 


desired interrupt. Interrupts zero and one cannot be asserted if selected; these are 
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selected; these are reserved for the PC. Selecting DMA=1 allows DMA storage 
to PC memory, while a zero in bit two disables DMA. Bits zero and one are 
important because they select the source of the A/D conversion start. The conversion 


start selections are listed in Table 5. 


TABLE 5: A/D START CONVERSION METHOD 


SOFTWARE TRIGGERED A/D 


PET START ON RISING EDGE TRIGGER (pin 25) 


START ON PACER CLOCK PULSE (CTR2 out) | 





If "SOFTWARE TRIGGERED A/D" is selected, the conversion 1s begun by 
writing any number to the BASE ADDRESS. This causes the current address at 
which the MUX is pointed to be converted to its 12-bit digital form. The second 
selection allows for the conversions to be "EXTERNALLY TRIGGERED" by a 
rising edge digital signal placed on pin 25 of the card. The rising edge causes the 
address at which the MUX is pointing to be converted. The final start conversion 


selection utilizes the onboard pacer clock and two onboard counters to control the 
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conversion. In this mode counters 1 and 2 can be used to set the frequency of 
conversion. In this mode counter 1 is used serially in conjunction with counter 2 
causing the start of conversion. The rising edge of counter 2’s output square wave 
triggers the start of conversion. 

The next five registers all work in conjunction with each other. Figure 13 


shows the interrelationship of these five registers, and Figures 14 through 18 show 


the layout of each register. 


| 45V 
| 45V 
CONTROL REGISTER 45 (24) GATE 0 
BASE + 10 10K 
TRIG CTRO 
o CTR O IN 
5 3 | COUNTER 0 l 
кей © ur y Е 2 CTR 0 OUT 


OUT 

GATE 
E 10 MHz шар COUNTER 1 | | OUT 
[ЕП u 
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COUNTER2 | |OUT 

> er 

GATE | 


| 45V 
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< (25) TRIGGER 
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Figure 13: PACER CLOCK Control Register 
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BASE ADDRESS + 10 


2 l 0 





Figure 14: PACER CLOCK Control Register 


BASE ADDRESS + 15 





Figure 15: COUNTER CONTROL 


BASE ADDRESS + 12 





Figure 16: COUNTER 0 
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BASE ADDRESS + 13 





Figure 17: COUNTER 1 


BASE ADDRESS +14 





Figure 18: COUNTER 2 


The PACER CLOCK control register BASE ADDRESS+10 (Figure 14) is 
the interface between the board functions and the Intel 8254 programmable interval 
timer (PACER CLOCK). The remaining four registers are resident onboard the 8254 


and are accessible from the addresses shown. Programming the PACER CLOCK 
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control register consists of four possibilities. The selection for the purpose desired 
is CTRO=0 and TRIGO=1. This selection allows the COUNTER 2 output to 
control the start conversion. If desired this mode also allows pin 25 of the cards 
connector to affect the conversion. The pin 1s pulled up to +5V, and will always be 
high unless an external connection to pin 25 pulls the pin low which would disable 
conversion. 

The remaining COUNTERS 0 through COUNTER 2 can be loaded by 
selecting them through commands to the COUNTER CONTROL register (Figure 
15). Additionally, the mode of the 8254 is set up through the COUNTER 
CONTROL register. The operating mode of the PACER CLOCK must be selected 
from the 8254 data sheet. From the data sheet the desired mode selected for this 
application is mode three. This selects a repeating square wave at a frequency 
determined by numbers loaded in COUNTER 1 and COUNTER 2. 

To load any of the 8254 onboard registers, it is necessary to refer to the 8254 
data sheet. To load a counter, the COUNTER CONTROL must point a multiplexor 
internal to the 8254 at the desired counter. Loading COUNTER 1 requires a binary 
OIL IXXXX (X indicates it does not matter which binary number) to be written to the 
COUNTER CONTROL register (BASE ADDRESS + 15). Bits SCO=0 and SCI=1 
(refer to Figure 15) select the desired register. Bits RWl=1 and RWO=1 (RW 


which stands for READ WRITE) select a loading scheme for the desired register, 
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in this case the least significant byte first, then the most significant byte. To select 
COUNTER 2 binary 1011XXXX is loaded into the COUNTER CONTROL register. 
Bits SCO=1 and SC1=0 select COUNTER 2. The read/write bits are as previously 
described. The counters are loaded with numbers that make mode three create a 10 
ms square wave which is the desired sampling rate for the control laws’ [Ref 1]. 

Once the registers are loaded with values, then the COUNTER CONTROL 
register must be loaded with a value to enable the 8254 to operate in the desired 
manner to produce the desired output. Mode 3 produces a square wave whose 
frequency depends on the values loaded in COUNTER 1 and COUNTER 2. To 
select this mode a binary XX11X110 is loaded into BASE ADDRESS+15 the 
COUNTER CONTROL. With Reference to the 8254 data sheet, RW1 and RWO, 
select as before which byte is loaded first. The bits of COUNTER CONTROL 
M2=X, M1=1 and MO=1 select mode 3 which from the 8254 data sheet produces 
the desired square wave output. 

Once initialization is complete, the MUX begins sequencing through the 
desired channels scanning one channel per rising edge. The control laws’ sampling 
rate was established to be 10 milliseconds [Ref 1]. This sampling rate is 
accomplished by setting up the card for "EXTERNAL TRIGGER". Then loading 
numbers into COUNTERS 1 and 2 that create a 10 ms square wave out of 


COUNTER 2. The output of COUNTER 2 is then be fed into pin 25 of the card to 
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provide the rising edge of the "EXTERNAL TRIGGER" for the desired sampling 
rate. This method is preferred over Pacer Clock driven because that mode does not 
produce an interupt that can be polled from the STATUS REGISTER. The program 
in Appendix B polls the interrupt bit till set, then the mode of conversion is changed 
to "SOFTWARE TRIGGERED MODE", to allow conversion of the other channels. 
The programmed software allows the MUX to point at the desired number of 
channels to be converted. This is done prior to the interrupt being cleared and 
trigger control being returned to "EXTERNAL TRIGGER”. The interrupt 1s cleared 
by writing any value to the STATUS register. After the interrupt 1s cleared and the 
trigger is changed back to "EXTERNAL TRIGGER”, the MUX increments to the 
next channel to be scanned and waits for the next rising edge from COUNTER 2. 
After the channel 1s converted, the value can be read and assembled from 
base address and BASE ADDRESS + 1. The registers are shown in Figure 19 and 


Du 
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BASE ADDRESS 


A/D9 | A/DIO | A/DII `А/р12 








LSB 


Figure 19: A/D LSB Data and Channel Register 


BASE ADDRESS + 1 


A/DI | A/D2 | A/D3 | A/D4 | A/DS | A/D6 | A/D7 | A/D8 


MSB 





Figure 20: A/D MSB DATA 


As shown in Figure 19, the lower four bits of the BASE ADDRESS contain the 
channel that has been converted. The upper four bits contain the Least Significant 
Bit (LSB) of the converted channel. BASE ADDRESS - 1 contains the upper eight 
bits of the converted channel. To assemble the complete 12-bit word Borland C 


function "inportb(address)" is used to read the two register addresses. Then the 
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contents read from the BASE ADDRESS are rolled right four bits to remove the 
channel number, and leave the LSB. The contents read from BASE ADDRESS +1 
(Figure 20) are then rolled left four bits to make room for the LSB. To assemble the 
two numbers, they are bitwise ORed to make the complete 12-bit word. This process 
takes the inputted analog signal and converts the signal to a digital number between 
0-4096. 

The final register that has many convenient uses is the STATUS REGISTER 


(BASE ADDRESS + 8). The STATUS register is shown in Figure 21. 


BASE ADDRESS + 8 


E Ы 
EOC | U/B | MUX]| INT | CH8 | CH4 | CH2 | CHI 





Figure 21: Status Register 


The most significant bit of the STATUS register EOC indicates that the end of 
conversion has been received; EOC =1 means busy converting, while EOC =0 means 
conversion complete. The next bit U/B tells whether the input amplifier is in 


unipolar (U/B=1), or bipolar (U/B=0). MUX bit tells whether the input channels 
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are single-ended or differential. The INT bit tells whether an external pulse has been 
received on pin 25; INT=0 means no pulse, and INT=1 means a pulse has been 
received. This bit can be conveniently used for polling to set up the control law 
sampling rate, and later applications can be placed on the internal PC bus to free up 
the CPU. The final four bits tell at which channel the MUX is currently pointed. 
A program that converts input channels from analog to digital is included in the 


Appendix B. 
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VI. UTILITY SYSTEM 


A. UTILITY SYSTEM OVERVIEW 

The utility system incorporates many diverse systems on the Archytas 
vehicle. In general the utility systems include the systems needed to power the 
sensors, control system servos, and the electronic ignition. Additionally the system 
includes a method for getting signals from the sensors to the computer, and 
commands from the computer to the vehicle. All of these systems have to be 
contained compactly and securely in a housing aboard the vehicle. 

When NPS received the AROD vehicles they contained two forebody units 
which each contained all the electronics to operate the vehicles. Unfortunately no 
documentation was received, or available. Observations of the units’ complicated 
wiring coupled with no schematics made the aspect of using the existing wiring 
impossible. With this in mind the tasks were to gather the data sheets on the sensors 
and establish what power systems were available and engineer a new system. The 
other task was to make the utility housing self contained and able to be attached to 
both the vehicle and the umbilical. 

The direction taken was to get one control system roll-rate completely 


connected. This control system would unmask many hidden hardware problems and 
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make the addition of other sensor connections easier. The systems connected were 
the power for ignition, power and signal for servos, and the power and signal 
connections for the roll-rate sensor. 

One of the first steps in the process was to adapt the housing to the vehicle. 
Since the early tests are to be done with the vehicle attached to the umbilical, the 
housing was designed to be attached to the bottom of the vehicle between the vanes. 
This additionally provides a degree of stability. Figure 22 shows the housing 


attached to the vehicle; Figure 23 shows the housing alone. 
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1. Power Routing and Connection 

The next step was to begin routing power to meet each system’s 
requirements. From the original AROD configuration the housing unit contained 
various DC-to-DC converters. These are units whose output is a specified constant 
once the input reaches a certain minimum value. The configuration from the original 
AROD comes with power supplies that can conveniently power the sensors, 
electronic ignition, and servos. Available power supplies on the unit are +/- 5V, 
+12V, +/- 15V, and +28V. As shown on the schematic in Appendix D, the 
power supply to the servos is +5V. This is wired directly from a +5V converter 
through Futaba J connectors (to allow disconnection for housing removal) to the five 
S-134 Futaba servos. 

The electronic ignition for the engine requires +28V. This is wired 
from the +28V DC converter through a Futaba G connector. The connector contains 
ground, +28V and a return line for the tachometer from the electronic ignition which 
is routed back through to the umbilical to allow measurement of engine RPM. 

The only sensor wired up is the single axis roll-rate sensor whose data 
sheet is in Appendix C, and picture is shown in Figure 24 and 25. Wiring this 
control system sensor allowed the connection of the output of the sensor through a 
conditioning card to the umbilical ending up at the A/D card which provides the input 


from the vehicle in computer-usable form. The control laws can then be applied to 
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the vehicle input. The computer can then generate the correct PWMS for the vehicle 
from the Quartz I/O card and send it back through the umbilical to the servos to 
correct the vehicle’s roll-rate. The sensor requires +/- 15V to power up. This 
sensor is connected to the appropriate power supply through a Futaba G connector 
to allow removal of the sensor from the housing. The data sheets for the remaining 
sensors that will require installation are included in Appendix C along with pictures 
of each. 

The next step in the hardware connections was to provide a means for 
the vehicle to receive power from the onboard generator, or have power provided 
externally until engine ignition. The original AROD had a card with a group of 
diodes arranged 1n a fashion to allow dual power sourcing. This card was adapted 
to fit inside the housing and wired to allow external connection for power through 
plugs, and wired to the onboard generator. This card allowed external power 
connection to power servos, ignition, and sensors prior to the engine running. After 
the engine 1s running and the generator 1s supplying power, the external connections 


can be removed to provide the ability for independent flight. 
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Figure 25: Roll-Rate Sensor (lower) Pitch and Yaw Sensor (upper) 
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2. Signal Connection and Routing 

Once power is applied to each of the devices, the controlling signal must 
be connected. The servos each require a PWMS to be connected that 15 originated 
at the computer. This is accomplished by connections from the umbilical through a 
connector. Then the signal is routed through the housing and joined as the third wire 
in the Futaba J connectors that connect the power to each servo. This means that the 
servos are each connected to a 3-wire Futaba J connector that contains ground, +5V 
and a PWMS. This connection is shown on the schematic in Appendix D. 

The connected roll-rate sensor signal output is a +/-2.5 VDC that 
correlates to +/-100 degrees/second of roll rate. This outputed roll rate needs to be 
conditioned to the 0-5V range that the A/D card is set up to convert. The signal 
from the roll-rate sensor 1s sent from the sensor to a conditioning card that was 
developed by AROD engineers. Once the sensor output is conditioned to the 
necessary voltage range of 0-5V, the signal is then routed to the umbilical through 
connectors as shown on the schematic in Appendix D. 

The umbilical provides a means of sending the PWMS to the vehicle 
to control the servos. Additionally, the umbilical provides routing for the roll-rate 
sensor signal and the tachometer. The umbilical is an unshielded cable that is 
connected to the vehicle through a cannon plug on the housing shown in Figure 26, 


and to the computer by connections shown in Figures 27 and 28. Figures 27 and 
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28 show the cables run from the A/D card and the Quartz I/O card that are installed 
in the computer. Additionally shown in both figures is the joy stick that commands 
roll-rate and throttle. The terminal block shown in both figures allows connection 
of the Umbilical to both cables. The breadboard has a unity gain amplifier wired that 
was used to protect the Quartz card outputs which did not have, but needed buffered 


outputs. 
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Figure 27: Umbilical Connection to Computer 
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Figure 28: Umbilical Connection to Computer 
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VII. SYSTEM TESTING, CONCLUSIONS AND RECOMMENDATIONS 


A. SYSTEM TESTING 

Testing of the various systems has occurred at various stages of the project. 
The ability to control movement of the vanes became important and was tested when 
static thrust and torque measurements were needed during the summer of 1992. The 
Archytas vehicle test stand allowed the computer to move the vanes and throttle 
through the umbilical during engine operation. The ability to command the throttle, 
and one or all four vanes incrementally was instrumental in making accurate 
measurements of the desired parameter. 

The A/D system was tested and utilized when ıt became necessary to model 
the Futaba S-134 servos that control the vanes to determine the frequency response 
for incorporation in the control laws [Ref 1]. The data gathered for the modeling 
was accomplished by commanding a unit impulse signal into the S-134 servo. Then 
the programmed A/D card allowed sampling of the position of the feedback 
potentiometer inside the servo. 

Additionally the complete roll-rate system 1s being tested. The system 
incorporates the software control laws [Ref 1] into the hardware A/D, servo control, 


and utility systems. Early hardware problems continue to be resolved to allow 


B 


complete testing. As with all functional systems, the addition of any individually 
engineered system to other individually engineered systems is not accomplished 


without further modifications. 


B. CONCLUSIONS 
The desired goal of this investigation was to create a digital interface system 
for the Archytas UAV. This vehicle is a VTOL fixed wing airplane that is designed 
to hover to altitude, then transition to horizontal flight. The emphasis was to 
establish a complete system to convert onboard sensor information into computer- 
useable form, then allow the information, once processed, to output a signal to 
command attitude-controlling servos on the vehicle to control pitch, yaw and roll. 
This investigation accomplished the following: 
e The addition of a Quartz I/O card added to the PC and programming to create 
a Pulse-Width-Modulated Signal to control servos. 
€ The addition and programming of the Computerboards Analog-to-Digital card 
that sampled at the desired controller rate, and converted the inputed signals to 
a 12-bit digital useable signal. 
€ A self-contained housing was developed that attaches to the bottom of the 
Archytas vehicle and contains power supplies that allow operation of the roll- 
rate sensor, servos and the electronic ignition for the engine. These power 


Supplies can operate prior to engine ignition on external power, and after 
ignition on the engine's generator. 
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Problems developed in several areas during the development of the above 
systems. The servos were deemed to be have limitations for the purpose of 
controlling the vanes. The servos limited torque, and plastic gears make failure a 
real possibility. The umbilical cable was determined to have noise spikes traversing 
the cable to the point of shorting the output amplifiers on the AM9513A (Quartz I/O 
card) causing replacement of the chip. This problem led to the addition of a unity 
gain amplifier installed in line with the cable to protect the computer card. The 
conditioning card schematics obtained from Sandia Laboratories were determined to 
be inaccurate and require further investigation for use with the remaining sensors. 
With any physically controlled and controllable system much time can be spent 
adjusting programs and locating bugs that cause unwanted behavior. The addition 
of wiring adds the additional problems of unwanted noise, and imperfect ог 
sometimes bad connections. Overcoming these types of problems provide the best 


real-world lessons and a feeling of accomplishment. 
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C. RECOMMENDATIONS 
In continuing work toward a fully-flyable vehicle, specific recommendations 
include : 
€ Addition of the remaining sensors, and incorporation of the remaining control 
laws for stability. 
e Obtaining a shielded umbilical cable to remove the noise problems. 


e The purchase of adequate servos that operate off PWMS and develop adequate 
torque for the given job. 


e Investigating the addition of DMA to the Computerboards A/D card to facilitate 
obtaining all sampled channels quicker. This would additionally free up the 
CPU tme. 


e Establishing an interrupt system that will be generated from the Computerboards 
A/D card and placed on the PC bus. This would eliminate the need for polling 
and release the CPU to accomplish other functions. 


e Development of a three-axis test stand that will allow testing of all axes of 


motion on the vehicle housing to establish validity of the control laws applied 
to the utility system. 
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APPENDIX A: PROGRAM GENERATES PWMS 


m 
Written by: Lt. Paul Merz 
Revised: 11/29/92 
For: Masters Thesis applied to the Archytas air vehicle 


This program is written in Borland C compiled and run in version 
2.0. The program utilizes the Quartz I/O card to generate 
Pulse-Width -Modulated signals (PWMS) of varying duty cycles from 
.6 to 2.4 ms. The signal 1s produced out of all 5 of the cards 
counters and 1s designed to vary the position of any servo connected 
to the counters. The program 1s designed to be user driven with 
the following servo connections: 
+5v pin 49 to red wire of servo 
gnd pin 50 to black wire of servo 
PWMS any of pins 5,11,17,23 or 39 


To operate the card must be strapped prior to installation for the 
address that will be declared as "datreg". 


Ref: Quartz I/O User's Manual E 
finclude <dos.h > /* preprocessor control lines: 'include' ч 
#include < stdio.h > /* inserts a copy of <*.h> at this point uli 
int datreg = 544; /* declare 'datreg' this 1s the base address 

strapped prior to card 
installation = 
int conreg = 545; /*declare ’conreg’ as integer value 545 = 
main() /* functn ’main’ executes main body of program*/ 
| 
initialize(); /* functn calls ’initialize’sets up registers */ 
chgangle(); /* functn 'chgangle' executes endless loop to change 
vane positions D 


j 
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Жжжж ЕКОЕ ОЕ НЕО ОБОО БОЕ ЖЕ Е Е ООЗЕ ЕО ОА 
ји 
/* changle 1s a subroutine that converts a user input into a integer 

number that can be placed in the load register to change the width 

of the outputed pulse width. The software allows the selection of 

any of the 5 channels on the Quartz card. After selection the user 


inputs an integer number that will be converted to a change in PWMS.*/ 
Ж ЖЖЖЖЖЖЖ Ж ЖЖЖ OK SK OR OR SKK ЖИЖИ U ET ET а ааа 


uod 


chgangle() 


int 1,hibyte,lobyte,angle,cmnd,vane; /* declare variables as integers */ 
angle = 1; /* since angle always > O, this causes 2 
while (angle > 0) /* endless loop P 


printf("ENTER THE VANE NUMBER TO CHANGE 1 TO 515); 
scanf("%d",&vane); /* inputs the value of vane between 1 & 5 */ 


vane — vane t 8; /* adding 8 changes the binary value so that*/ 
/* 'vane' can be used to label an address */ 
/*that ıs translatable to a counter | 


printf("ENTER THE DESIRED ANGLE \n "); 


scanf(" %d" ,&angle); /* input the desired vane angle in 

degrees */ 
angle =((1900/206)*angle +600); /* algorithm to conv fm deg to dig # */ 
hibyte =(angle/256); /* forms high byte  */ 
lobyte = (angle-hibyte*256); /* forms low byte = 
стпа = 193; /ж 193 = 1100 00015 e 
outportb(conreg,cmnd); /* dısarms counter | =, 
cmnd —vane; /* between 9 & 13-2 0000 10016 & 0000 11016*/ 
outportb(conreg,cmnd); /% select load register of desired counter */ 
outportb(datreg,lobyte); /* lower byte of # to load reg ч 
outportb(datreg,hibyte); /* upper byte of # to load reg = 
cmnd =233; /* 233 = 1110 1001b B 
outportb(conreg,cmnd); /* sets toggle high for counter | k 
cmnd — 97; /* 97 = 0110 00016 = 
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outportb(conreg,cmnd); /* loads (fm load reg) and arms counter 1 */ 
y end while*/ 
! /*end chgangle*/ 


/* Initialize sets up the Quartz card to operate in mode j which 
allows the card to generate the PWMS out of all 5 counters. 
it also sets up various other functions that are not used for 
the purpose of the archytas a 


initialize() 
{ 


int cmnd,1; 


printf("start of process\n"); 


cmnd=255; /* 255 = 1111 1111b 7 
outportb(conreg,cmnd); /* resets all board functions 
cmnd =23; /* 23 = 0001 0111b = 
outportb(conreg,cmnd); /* select master mode register ү 
стпа=176; /* 176 = 1011 0000b E 
outportb(datreg ,cmnd); /* Jow byte: FOUT source ıs Fl Ж 
cmnd — 65; /* 65 = 0100 00016 D 


outportb(datreg,cmnd); ^ /* high byte: binary division, | 
disable increment, | MODE 


8-bit bus width, е е 
FOUT on, divide by 1 | ici 
стпа = 249; /* 249 = 1111 10016 d 
outportb(conreg,cmnd);  /* disable prefetch for write operations  */ 
for @=151< =5;1+ +) 
| 
cmnd =i; /* 1 to 5 = 0000 0001b to 0000 01016 = 
outportb(conreg,cmnd); /*select ctr mode reg of group 1 thru 3 */ 
cmnd —98; /* 98 = 0110 0010b at 


outportb(datreg,cmnd); /* low byte: disable special gate, 
reload from load or hold, 
count repetitively, 
binary count, 
count down, 
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TC toggled #/ 
cmnd =27; /* 27 = 0001 19116 2 
outportb(datreg,cmnd); /* high byte: no gating for counter 1 thru 5 
count on falling edge, 
count source Fl i 


j 


[ог = 2516 =29леВ==) 

| 
cmnd =1; /* 25 to 29 = 0001 1001b to 0001 1101b %/ 
outportb(conreg,cmnd); /* load hold registers for refresh rate — */ 
cmnd =0; /* 0 - 0000 0000b = 
outportb(datreg,cmnd); /* load low byte into hold register / 
cmnd 231; /* 31 = 0001 1111b T, 
outportb(datreg,cmnd); /* load high byte into hold register ч 

/* combined lo & hi: 7936 gives refresh rate */ 


j 

Юг (1=291< =131+ +) 

l 
cmnd =1; /* 9 to 13 = 0000 1001b to 0000 1101b С 
outportb(conreg,cmnd); /* select load register for pulse width */ 
cmnd=110; /* 110 = 0110 11106 a 
outportb(datreg,cmnd); /* load low byte into load register = 
cmnd —5; /* 5 = 0000 01015 = 
outportb(datreg,cmnd); /* load high byte into load register = 

/* combined lo & hi: 37430 gives pulse width */ 

j 

[eg (nc 200 = үү, 

f [58933 = 1 ШОШ = 
cmnd=1; /* 237 = 1110 1101b 7 
outportb(conreg,cmnd); /* set toggle high for counters 1 thru 5  */ 

j 

стпа = 127; /* 127 = 0111 11116 | 

outportb(conreg,cmnd); /* load and arm counters 1 thru 5 ы, 


printf(" COMPLETED INITIALIZATION OF SERVOS n"); 
) 
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DES 


APPENDIX B: PROGRAM FOR A/D CONVERSION 


Written by: Paul Merz 
Revised: 11/29/92 
For: Masters Thesis on the Archytas air vehicle 


This program is written to be compiled in Borland C 2.0. 

The program is a combination of the program similar to 
Appendix A and a program to convert 3 channels from analog 
to digital utilizing the CIO-AD16jr Computerboards card. 

The program utilizes a 10ms interrupt to trigger conversion. 
Once the interrupt is received the mode on the CIO-AD16jr card 
is changed to software triggered then three channels are 
converted. Once converted the status register 1s reset to 

allow further interrupts, and the mode is changed back to 
external triggered to allow the interrupt to begin the process again. 


The following are connections to be made: 
Pin 7 grnd 
Pin 20 connects to pin 25 
Pin 35,36 and 37 are channels to be converted 


This program was utilized to allow testing of the process of 
bringing an analog signal in similar to that of the roll rate 
sensor, throttle and commanded roll-rate, then outputing some 
new value to the control vanes to change the vane position. 


E 
finclude < dos.h > | 
#include < stdio.h > 
int datreg = 544; /* QUARTZ CARD base address E 
int conreg — 545; /* QUARTZ CARD base address +1 i 
int basaddr = 768; /* A/D CARD base address D 
int. basepll —7609; /* A/D CARD base address +1 ш, 
iniemux- 770; /* A/D CARD base address +2 sí 
int statreg —776; /* A/D CARD base address +8 7 
int intcont — 777; /* A/D CARD base address +9 = 
int pclock=778; /* A/D CARD base address +10 i 
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int inrange — 779; /* A/D CARD base address + 11 ји. 
int cntr] — 7396 /* A/D CARD base address +13 N 
шп "спрат /* A/D CARD base address +14 N 
int cntrcon=783; /* A/D CARD base address +15 ®/ 
int. lookup[70],angle,newangle,throttle,nthrottle; /* GLOBALS 
declared as integers */ 


main() 


initializeQ); 
setup; 
sample(); 


) 


J >< *K >K >K >K 2K >K ООСС ОСС ЩЖ С К ж КОЖО ОВО ОК E e e Е КИИИН 


/* This section (initialize()) 1s similar to Appendix A i 
ЖЖЖ ЖЖ ЖЖ ЖЖЖ ЖЖ ЖЖЖ ЖЕЖ ЖЖЖ ЕК КОВ В M 


initialize() /* INITIALIZES QUARTZ CARD */ 
int cmnd,1,angle; 


printf("start of process\n"); 
cmnd =255; 
outportb(conreg,cmnd); /*reset all board functions*/ 
cmnd =23; 
outportb(conreg,cmnd); /*select master mode regıster*/ 
cmnd=176; 
outportb(datreg,cmnd); /*low byte enables fout*/ 
стпа =65; 
outportb(datreg,cmnd); 
cmnd =249; 
outportb(conreg,cmnd); 
for 1 =1:1< =5;1+ +) 
l 
cmnd =i; /*select group 15% 
outportb(conreg,cmnd); 
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стпа =2; /*low byte set modes of counter 1 in cmr*/ 
outportb(datreg ,cmnd); 

стпа =27; /*high byte по gating for counter 1*/ 
outportb(datreg,cmnd); 


ИЕ 291 < =307+-) 
t 
cmnd =1; /*]oad the hold register for refresh rate*/ 
outportb(conreg,cnınd); 
cmnd =0; 
outportb(datreg,cmnd); 
cmnd= 10; 
outportb(datreg,cmnd); 


for (129; « 213; +) 


l 


стпа =1; /*select load register for pulse width*/ 
outportb(conreg,cmnd); 

cmnd — 103; /*load low byte into load register*/ 
outportb(datreg,cmnd); 

cmnd = 7: 


outportb(datreg,cmnd); 


[ог (1=2331< =2371 + +) 
t 


cmnd =1; 
outportb(conreg,cmnd); 


cmnd= 127: /*]oad and arm counter 1*/ 
outportb(conreg,cmnd); 


for (1=9;1< =13;1++) 


l 


cmnd=1; /*select load register for pulse width*/ 
outportb(conreg,cmnd); 

стпа = 110; /*load low byte into load register*/ 
outportb(datreg,cmnd); 

cmnd=5; 


outportb(datreg,cmnd); 
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for (42233; 1«—25 7 Те 
| 
emnd=1; 
outportb(conreg,cmnd); 


СИВО /*load and arm counter 1 */ 
outportb(conreg,cmnd); 

for (1=1;1< =70;1+ +) lookup[i] 2 50-1; 

printf(" COMPLETED INITIALIZATION OF SERVOS\n"); 


) 


ЖЖЖ ЖЖ ЖЖЖ ЖЖЖ ЖЖ ЖЖЖ ЖЖЖ ЕЕ ЕЕ ааа ааа А ТА СНОСИ 


Setup initializes the CIO-AD16jr сага іо ргоуіае а 105 ош 
of counter 2 out. The square wave frequency is set up by 
the values loaded in counter 1 and 2. The card is set up 


to sample chanels 0-3. 
ЖЖЖ ЖЖЖЖЖЖЖЖЖ ЖЖЖ ЖЖ ЕЕ аа ааа” 


setup() /* INITIALIZES A/D CARD */ 
int cmnd; /* declare cmnd as integer */ 
стпа = 32; /* 32 = 0010 00006 */ 
outportb(mux,cmnd); /* set the mux to read channels 0-2 */ 
cmnd =2; /* 2 = 0000 0010b */ 


outportb(intcont,cmnd); /*set up pacer clock for clock driven 
sampling */ 
cmnd=5: /*5 = 0000 0101b*/ 
outportb(inrange,cmnd); /*set up for correct input and 
type of voltage */ 


[PB AR AR AG Ae Ae Ae Ae Ae Ae Ae Ae Ae XE He He 2K X; >i >K 2k 2k K Sk Sk oie oie ok IE IE ok vj ole vie vie vie ve zie oie oie oie oie oie | 


/*sets up 10 ms square wave out of counter 2*/ 
| HE IE E E IE E E FE IE IE FE IE E EE EE Е ЖЖ ЖЕ. 


стпа = 118: /*FM DATA SHEET: SC-01, RW-11, M-011, 
BCD-0 - */ 
outportb(cntrcon,cmnd); /*CTR 1, READ/WR LSBYTE IST, MODE 3, 
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BINARY */ 


cmnd = 100; /*100 IN LOWER BYTE set up counter 1*/ 

outportb(cntrl,cmnd); 

cmnd =0; / FE UIN UPPER BYTE set Up counter l*/ 

outportb(entrl,cmnd); 

cmnd= 182; /* FM DATA SHEET: SC-10, ЕМ-11, М-011, 
ВСО-0 - */ 

outportb(cntrcon,cmnd); /*CTR 2, READ/WR LSBYTE IST, MODE 3, 
BINARY */ 

стпа = 100; /*100 IN LOWER BYTE for counter 2*/ 

outportb(cntr2,cmnd); 

emnd=0; /*0 IN UPPER BYTE for counter 2*/ 


outportb(cntr2,cmnd); 
printf(" COMPLETED CARD INITIALIZATION n"); 


j 


ИИ е Е E A SE SK >K cie ole SiS oie Sie ot DIG oe OK OK IS SK OK DK o Do o / 


/* Sample does the work of checking the interupt, once the 
interupt 1s found the conversion process is changed to 
software driven to sample the three desired channels. 
each of these 1s assembled into a 12-bit word to be used 
later. Once all channels are sampled the interrupt 15 
cleared and the trigger 1s changed to external triggered 
mode. This procedure allows the throttle to be input from 
a Joystick then converted to a PWMS to change the position 


of a servo attached to channel 5 of the Quartz card n 
SEE EEE EI ne леме меси он ан IS NOR OR ORO OK РК R SE SR SF >K РК УК РК КУК УК ОК ОН ОК К AE Si 5 KOK OR / 


затрје() /* EXERCISES A/D CARD */ 
int x,cmnd,lsb,1sbl,1sb2,1sb3,sreg,turnangle; 
x=1; /* forces continuous loop*/ 
while (x==1) 


| 


sreg — inportb(statreg); /*read status reg to check 
interrupt bit */ 
sreg — sreg&ló; /* 'and' with 16 to get only 5th bit info */ 
if (sreg==16)  /* 5th bit is interrupt bit- 1f high, 
external pulse has been recvd, 
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i.e. ready to get data = 


шша = 32: /* 32 = 0010 00006 = 
outportb(mux,cmnd); /* set the mux to read channels 0-2 */ 
стпа =0; 


outportb(intcont,cmnd); /*SOFTWARE TRIGGERED A/D ONLY */ 
outportb(basaddr,cmnd); /*IMMEDIATE A/D CONVERSION */ 
lsb = inportb(basaddr); /*“READ LOW BYTE, MSB-8 TO LSB 

+ CHANNEL*/ 
Isbl — inportbí(basepll); /*READ HIGH BYTE, MSB TO MSB-7*/ 


sb = 1b > a /*ROLL LSBYTE RIGHT 4 BITS*/ 
1561 = 1561 « « 4; /*ROLL MSBYTE LEFT 4 BITS */ 
Isbl = 1561 ! lsb; /* ’OR’ TO GET 12 BIT INFO*/ 
cmid = 0 


outportb(basaddr,cmnd); /*IMMEDIATE A/D CONVERSION*/ 
lsb — inportb(basaddr); /'*READ LOW BYTE, MSB-8 TO LSB 

+ CHANNEL */ 
Isb2 = inportb(basepll); /*READ HIGH BYTE, MSB TO MSB-7*/ 


Ish = lsb >> 4; /*ROLL LSBYTE RIGHT 4 BITS*/ 
lsb2 = Isb2 < < 4; /*ROLL MSBYTE LEFT 4 BITS*/ 
Isb2 = Isb2 | Isb; /*’OR’ TO GET 12 BIT INFO*/ 
emma- 0: 


outportb(basaddr,cmnd); /*IMMEDIATE A/D CONVERSION*/ 
Isb = inportb(basaddr); /*READ LOW BYTE, MSB-8 TO LSB 
+ CHANNEL */ 


|sb3 — inportb(basepll); /;FREAD HIGH BYTE, MSB TO MSB-7*/ 
lsb = lsb >> 4; /*ROLL LSBYTE RIGHT 4 BITS*/ 

1503 = 1503 < < 4; /*ROLL MSBYTE LEFT 4 BITS*/ 

[563 = 1563 | 155; /*'OR  TOsSGET 12 BI INFEO*/ 

emnd=2; 


outportb(intcont,cemnd); /*RETURN TO PACER CLOCK DRIVEN 
SAMPLING */ 


cmnd=ınportb(statreg); /*read status register, 
then write back */ 
outportb(statreg,cmnd); /*to ıt same #- causes reset 
of flip-flop*/ 
/* so that interrupt bit 1s set to 0*/ 
throttle— (int)((1sb2-2714)*.127 4- 50) 
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/* calculate throttle #*/ 
chgangle(); /* call function chgangle() */ 
nthrottle — throttle; 

j 
j 
j 


LLL DO UU debere ET ааа E OE E E E E E E E E E 2E 2E E 2E E 2F EF | 


/* Chgangle is the same as described in Appendix A */ 


ИШ Boer ЕЕ ООО у 


chgangle() /* EXERCISES QUARTZ CARD */ 


int 1,hibyte,lobyte,angle,cmnd,vane; 


angle —((1900/206)*newangle +600); 
hibyte =(angle/256); 

lobyte = (angle-hibyte*256); 

cmnd 2207; 

outportb(conreg,cmnd); 


for ü = 9; i < = 12;i+ +) 
{ 

outportb(conreg,1); 

outportb(datreg,lobyte); 

outportb(datreg,hibyte); 


Гог (1 = 2331 < = 2361+ +) ошрогб(сопгег,1); 


стпа =111; 
outportb(conreg,cmnd); 
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cmnd —208; 
outportb(conreg,cmnd); 
angle =((1900/206)*nthrottle + 600); 
hibyte — (angle/256); 

lobyte = (angle-hibyte*256); 
cmnd=13; 
outportb(conreg,cmnd); 
outportb(datreg,lobyte); 
outportb(datreg,hibyte); 
cmnd =237; 
outportb(conreg,cmnd); 
стпа = 112; 
outportb(conreg,cmnd); 
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Figure 31: 3-Axis Accelerometer 
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QA-700 Technical Data 












































p ee CI A 
Output Range - 309 Operating Temperature 
ee ui Bmg max For Specified Performance -53:C to NN 
Bias Thermal Cce'^ cient ЕЕ 70.9 .g °C max Storage Temperature -65* to -125*€ 
Current Scale Factor E, 1 3mA g nom Stat c Acceleration Overrange Limit 100g peak 
Scale Factor Thermal Coefficient 200 ppm *C max Shock Limit Е 250g peak. 6 msec. half sine 
Linearity Error 4Bug g: max oine Vibration Limit 259 peak. 50 to 2000 op 
Input Axis Misalignment 7mrad PHYSICAL 
Resolution Thresnold | lug max Weight 50 grams max 
Frequency Response ОУ ЧУ 0 190 тах Case Material Stainless Steel 
10-100 Hz -4% тах 
100-300 Hz =5% max MOUNTING 
Damping Ratio 0.3 to 0.8 3 or 4 Point Mounting Adapters 


Available Upon Request 








ELECTRICAL 

Input Voltage =13 УрСло = ПЕК ВО 

Quiescent Current max 20mA per supply 

Isolation. case to all pins 10 megohms at 50 VDC 

Temperature Sensor Output a e Lio ipse 


"Temperature Modeling available on request | 
! 


e e| I, 33 TO -1 voc 
INPUT 


5 _ POWER AND 
SIGNAL GROUN. 


LOAD RESISTOR 
(USER SUPPLIED} 


=¬ 
| 


| 

| SIGNAL OUTPUT 
| ! TORQUER 

| сон 

! | 

| 

| 

I 

| 

| 


i 

| SERVO тко 
[qe OETECTOR AMPLIFIER 

| 

| 

| 





2. BUILT IN TEST 
(CURRENT) 


15K! 


38۷32 


Y A BUILT IN TEST 
(VOLTAGE) 


REGULATEO 


| 
9 |, +10 voc 
| OUTPUT 






-10 VDC 


— e R£GULATED 
OUTPUT 


27.9mm 
max 






$ m FACTORY TEST 
ONLY 





TEMP SENSOR 


| 
| 
| 
TEMP SENSOR | 
| 
| our 


PIN NUMBERS 


For addıtıonal ınformatıon on specific requirements. direct all inquiries to the Marketing Department, Instrument 
Systems Division. Sundstrand Data Control. Inc. Redmond Washington USA AC 206:885-3711 or our authorized 
representative noted oelow 


Sundstrand Data Control, Inc. (А 


BES HAST Dr 


~ 
' yS asg! na ч/. 
77 25:72 wa eos s 


Printed ir USA 86-209 2108 886 
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